home *** CD-ROM | disk | FTP | other *** search
/ EnigmA Amiga Run 1999 March / EnigmA AMIGA RUN 35 (1999)(G.R. Edizioni)(IT)[!][issue 1999-03].iso / earcd / grafica / amhelios / hc_delta.cpp < prev    next >
C/C++ Source or Header  |  1999-01-01  |  2KB  |  84 lines

  1. ////////////////////////////////////////////////////////////
  2. //
  3. //  HC_DELTA.CPP - Hemicube Delta Form Factor Class
  4. //
  5. //  Version:    1.03A
  6. //
  7. //  History:    94/08/23 - Version 1.00A release.
  8. //              94/12/16 - Version 1.01A release.
  9. //              95/02/05 - Version 1.02A release.
  10. //              95/07/21 - Version 1.02B release.
  11. //              96/02/14 - Version 1.02C release.
  12. //              96/04/01 - Version 1.03A release.
  13. //
  14. //  Compilers:  Microsoft Visual C/C++ Professional V1.5
  15. //              Borland C++ Version 4.5
  16. //
  17. //  Author:     Ian Ashdown, P.Eng.
  18. //              byHeart Software Limited
  19. //              620 Ballantree Road
  20. //              West Vancouver, B.C.
  21. //              Canada V7S 1W3
  22. //              Tel. (604) 922-6148
  23. //              Fax. (604) 987-7621
  24. //
  25. //  Copyright 1994-1996 byHeart Software Limited
  26. //
  27. //  The following source code has been derived from:
  28. //
  29. //    Ashdown, I. 1994. Radiosity: A Programmer's
  30. //    Perspective. New York, NY: John Wiley & Sons.
  31. //
  32. //  It may be freely copied, redistributed, and/or modified
  33. //  for personal use ONLY, as long as the copyright notice
  34. //  is included with all source code files.
  35. //
  36. ////////////////////////////////////////////////////////////
  37.  
  38. #include "hc_delta.h"
  39.  
  40. // Static delta form factor arrays
  41. float HemiDelta::side_array[HC_ArrayDim][HC_ArrayDim];
  42. float HemiDelta::top_array[HC_ArrayDim][HC_ArrayDim];
  43.  
  44. HemiDelta::HemiDelta()  // Class constructor
  45. {
  46.   int i, j;             // Loop indices
  47.   double da;            // Cell area
  48.   double dx, dy, dz;    // Cell dimensions
  49.   double r, x, y, z;    // Cell co-ordinates
  50.  
  51.   // Initialize cell dimensions and area
  52.   dx = dy = dz = 2.0 / (float) FF_ArrayRes;
  53.   da = 4.0 / ((float) FF_ArrayRes * (float) FF_ArrayRes);
  54.  
  55.   // Calculate top face delta form factors
  56.   x = dx / 2.0;
  57.   for (i = 0; i < HC_ArrayDim; i++)
  58.   {
  59.     y = dy / 2.0;
  60.     for (j = 0; j < HC_ArrayDim; j++)
  61.     {
  62.       r = x * x + y * y + 1.0;
  63.       top_array[i][j] = (float) (da / (PI * r * r));
  64.       y += dy;
  65.     }
  66.     x += dx;
  67.   }
  68.  
  69.   // Calculate side face delta form factors
  70.   x = dx / 2.0;
  71.   for (i = 0; i < HC_ArrayDim; i++)
  72.   {
  73.     z = dz / 2.0;
  74.     for (j = 0; j < HC_ArrayDim; j++)
  75.     {
  76.       r = x * x + z * z + 1.0;
  77.       side_array[i][j] = (float) (z * da / (PI * r * r));
  78.       z += dy;
  79.     }
  80.     x += dx;
  81.   }
  82. }
  83.  
  84.